package br.com.websec.carteira;

import java.util.List;

import org.apache.log4j.Logger;
import org.hibernate.HibernateException;
import org.hibernate.Session;

public class CarteiraDaoHibernate implements CarteiraDao {
	
	private static final Logger logger = Logger
	.getLogger(CarteiraDaoHibernate.class.getName());
	private Session session;

	public void setSession(Session session) {

		this.session = session;

	}


	@Override
	public void salvar(Carteira carteira) {
		try {
			this.session.save(carteira);

		} catch (HibernateException e) {
			logger.error("Não foi possível salvar objeto Carteira na base.: "
					+ e.getMessage());
		}

	}

	@Override
	public void excluir(Carteira carteira) {
		try {
			this.session.delete(carteira);

		} catch (HibernateException e) {
			logger.error("Não foi possível excluir objeto Carteira da base.: "
					+ e.getMessage());
		}


	}

	@SuppressWarnings("unchecked")
	@Override
	public List<Carteira> listaPorConta(Integer conta) {
		
		String hql = "select  c from Carteira  c where c.idConta = :idconta";
		org.hibernate.Query query = this.session.createQuery(hql);
		query.setParameter("idconta", conta);
		return (List<Carteira>) query.uniqueResult();
		

	}



	@Override
	public Carteira listaPorId(Integer carteira) {
		String hql = "select  c from Carteira  c where c.idCarteira = :idcarteira";
		org.hibernate.Query query = this.session.createQuery(hql);
		query.setParameter("idcarteira", carteira);
		return (Carteira) query.uniqueResult();
		
	}


	@Override
	public void alterar(Carteira carteira) {
		this.session.update(carteira);
		
	}


	@Override
	public Carteira buscarPorNumeroCarteira(Integer numeroCarteira) {

		String hql = "select  c from Carteira  c where c.numeroCarteira = :numeroCarteira";
		org.hibernate.Query query = this.session.createQuery(hql);
		query.setParameter("numeroCarteira", numeroCarteira);
		return (Carteira) query.uniqueResult();
		

	}

}
